<template>
  <!-- // 分配角色 -->
  <div>
    <el-checkbox-group v-model="roleIds">
      <el-checkbox
        v-for="item in list"
        :key="item.id"
        :label="item.id"
      >{{ item.name }}</el-checkbox>
    </el-checkbox-group>

    <div style="margin-top: 20px; text-align: right">
      <el-button type="primary" @click="hSubmit">确定</el-button>
      <el-button @click="closeDialog">取消</el-button>
    </div>
  </div>
</template>
<script>
import { getRoles } from '@/api/settings'
import { getUserDetail } from '@/api/user'
import { assignRoles } from '@/api/employees'
export default {
  props: {
    curId: {
      type: String,
      required: true
    }
  },
  data() {
    return {
      roleIds: [],
      list: []
    }
  },
  created() {
    this.loadRoles()
  },
  methods: {
    async hSubmit() {
      try {
        await assignRoles({ id: this.curId, roleIds: this.roleIds })
        // 关闭弹层
        this.$emit('success')
      } catch (err) {
        console.log(err)
      }
    },
    // 获取角色
    async loadRoles() {
      try {
        const res = await getRoles({ page: 1, pagesize: 100 })
        const detail = await getUserDetail(this.curId)
        console.log('getRoles', res)
        this.roleIds = detail.data.roleIds
        // 保存数据
        this.list = res.data.rows
      } catch (err) {
        console.log('getRoles', err)
      }
    },
    // 关闭弹层
    closeDialog() {
      this.$emit('close')
    }
  }
}
</script>
